FluentQueries.java
package org.codefilarete.stalactite.query.model;
import java.util.Map;
import org.codefilarete.stalactite.query.api.CriteriaChain;
import org.codefilarete.stalactite.query.api.Fromable;
import org.codefilarete.stalactite.query.api.Selectable;
import org.codefilarete.stalactite.query.api.Selectable.SimpleSelectable;
import org.codefilarete.stalactite.query.builder.WhereSQLBuilderFactory.WhereSQLBuilder;
import org.codefilarete.stalactite.query.model.FluentQuery.FluentSelectClause;
import org.codefilarete.stalactite.query.model.FluentQuery.SelectAwareAliasExpression;
import org.codefilarete.stalactite.sql.ddl.structure.Column;
/**
* A utility class that offers static factory methods for query or criteria construction, eliminating the need for
* "new Query()" code followed by method chaining.
*
* @author Guillaume Mary
*/
public class FluentQueries {
public static FluentSelectClause select(Iterable<? extends Selectable<?>> selectables) {
return new FluentQuery().select(selectables);
}
public static <C> SelectAwareAliasExpression select(String expression, Class<C> javaType) {
return new FluentQuery().select(expression, javaType);
}
public static FluentSelectClause select(Selectable<?> expression, Selectable<?>... expressions) {
return new FluentQuery().select(expression, expressions);
}
public static FluentSelectClause select(Selectable<?> column) {
return new FluentQuery().select(column);
}
public static FluentSelectClause select(Selectable<?> column, String alias) {
return new FluentQuery().select(column, alias);
}
public static FluentSelectClause select(Selectable<?> col1, String alias1, Selectable<?> col2, String alias2) {
return new FluentQuery().select(col1, alias1, col2, alias2);
}
public static FluentSelectClause select(Selectable<?> col1, String alias1, Selectable<?> col2, String alias2, Selectable<?> col3, String alias3) {
return new FluentQuery().select(col1, alias1, col2, alias2, col3, alias3);
}
public static FluentSelectClause select(Map<? extends Selectable<?>, String> aliasedColumns) {
return new FluentQuery().select(aliasedColumns);
}
public static FluentQuery from(Fromable rootTable) {
FluentQuery fluentQuery = new FluentQuery();
fluentQuery.from(rootTable);
return fluentQuery;
}
public static CriteriaChain<?> where(Selectable<?> column, String condition) {
return new Where(column, condition);
}
public static <O> CriteriaChain<?> where(Selectable<O> column, ConditionalOperator<? super O, ?> condition) {
return new Where(column, condition);
}
public static CriteriaChain<?> where(Object... criteria) {
return new Where(criteria);
}
/**
* Shortcut to create a {@link Criteria}.
* Combined with {@link WhereSQLBuilder} it will add parenthesis around it.
*
* @param column a {@link Column}
* @param condition the criteria on the {@link Column}
* @return a new {@link Criteria}
*/
public static Criteria<?> filter(Selectable<?> column, String condition) {
return new Criteria<>(column, condition);
}
/**
* Shortcut to create a {@link Criteria}.
* Combined with {@link WhereSQLBuilder} it will add parenthesis around it.
*
* @param column a {@link Column}
* @param condition the criteria on the {@link Column}
* @return a new {@link Criteria}
*/
public static Criteria<?> filter(Selectable<?> column, ConditionalOperator condition) {
return new Criteria<>(column, condition);
}
/**
* Shortcut to create a {@link Criteria}.
* Combined with {@link WhereSQLBuilder} it will add parenthesis around it.
*
* @param columns a combination of objects describing the criteria
* @return a new {@link Criteria}
*/
public static Criteria<?> filter(Object ... columns) {
return new Criteria<>(columns);
}
public static <C> Selectable<Object> column(String name) {
return new SimpleSelectable<>(name, Object.class);
}
}